[PATCH] Correctly handle signed 32-bit time_t types
authorNoah Meyerhans <noahm@debian.org>
Thu, 5 Mar 2026 01:08:14 +0000 (20:08 -0500)
committerNoah Meyerhans <noahm@debian.org>
Thu, 5 Mar 2026 01:08:14 +0000 (20:08 -0500)
commit80a7609ce97af0c6b7d6b5947da3c9708ccb4499
treea3a03c5c6b99bb1179c584ce8645e0c258d24aef
parentd17beb9870aed87c65b93599efdd602f8c910399
[PATCH] Correctly handle signed 32-bit time_t types

Bug-Debian: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1124541
Forwarded: no

dovecot handles 32-bit time_t in a couple of different ways, but neither quite
works currently.  Setting TIME_T_MAX_BITS to 31 isn't correctly handled in
places where time_t values are constructed, for example in
io_loop_get_wait_time().

Similarly, setting TIME_T_MAX_BITS = 32 and defining TIME_T_SIGNED is not
correctly handled by tm_is_too_large().

This change fixes tm_is_too_large() to set max_time to the correct maximum date
representable by a signed 32-bit time_t.

Closes: #1124541
Gbp-Pq: Name Correctly_handle_signed_32-bit_time_t_types.patch
src/lib-imap/imap-date.c
src/lib-imap/test-imap-date.c